In the Claims : 



Please amend claims 1, 6, 9, 11, 16, 18, 20, 27, 30, 35-37, 45, and 51-62, as 
indicated below. 

1 . (Currently amended) A peer computing systen^ comprising: 

a plurality of peer nodes operable to couple to a network, wherein the plurality of 
peer nodes are configured to implement a peer-to-peer environment on the 
network according to a peer-to-peer platform comprising one or more 
peer-to-peer platform protocols for enabling the plurality of peer nodes to 
discover each other, communicate with each other, and cooperate with 
each other to form peer groups and share content in the peer-to-peer 
environmen t, and wherein each of the plurality of peer nodes is a host of 
content in the pccr-to-pccr environment ; 

wherein the plurality of peer nodes are partitioned by a mechanism on the 
network into a set of one or more peer nodes inside the mechanism and a 
set of one or more peer nodes outside the mechanism, wherein peer nodes 
on opposite sides of the mechanism cannot communicate directly with 
each other on the network; 

wherein one of the plurality of peer nodes is a relay peer node operable to couple 
to the network outside the mechanism, and further operable to: 

receive a message from a peer node outside the mechanism, wherein the 
message is for a peer node inside the mechanism; and 

relay the message to the peer node inside the mechanism. 
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2. (Original) The peer computing system as recited in claim 1, wherein the relay 
peer node is further operable to: 

receive a message from the peer node inside the mechanism, wherein the message 
is for the peer node outside the mechanism; and 

relay the message to the peer node outside the mechanism. 

3. (Original) The peer computing system as recited in claim 1, wherein the 
mechanism is a firewall. 

4. (Original) The peer computing system as recited in claim 1, wherein the 
mechanism is a Network Address Translation (NAT) gateway. 

5. (Original) The peer computing system as recited in claim 1 , wherein the relay 
peer node is further operable to cache route information describing one or more routes to 
peer nodes on the network. 

6. (Currently amended) The peer computing system as recited in claim 5, 
wherein, to relay the message to the peer node inside the mechanism, the relay peer is 
operable to use the cached route information to route the received message to the peer 
node outside inside the mechanism. 

7. (Original) The peer computing system as recited in claim 5, wherein the relay 
peer node is further operable to: 

receive a query requesting route information to one of the plurality of peer nodes 
from another one of the plurality of peer nodes, wherein the query is 
formatted according to an endpoint routing protocol; and 
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send the requested route information to the requesting peer node in accordance 
with the endpoint routing protocol. 

8. (Original) The peer computing system as recited in claim 5, wherein the route 
information includes an ordered sequence of peer identifiers configured for use in routing 
a message to a destination peer node. 

9. (Currently amended) The peer computing system as recited in claim 1, 
wherein the message includes route information, and wherein, to relay the message to the 
peer node inside the mechanism, the relay peer is operable to use the route information 
included in the message to route the received message to the peer node outside inside the 
mechanism. 

10. (Original) The peer computing system as recited in claim 9, wherein the route 
information includes an ordered sequence of peer identifiers configured for use in routing 
a message to a destination peer node. 

1 1 . (Currently amended) A peer computing system,, comprising: 

a plurality of peer nodes operable to couple to a network, wherein the plurality of 
peer nodes are configured to implement a peer-to-peer environment on the 
network according to a peer-to-peer platform comprising one or more 
peer-to-peer platform protocols for enabling the plurality of peer nodes to 
discover each other, communicate with each other, and cooperate with 
each other to form peer groups and share content in the peer-to-peer 
environmen t, and wherein each of the plurality of peer nodes is a host of 
content in the peer-to-peer environment ; 

wherein the plurality of peer nodes are partitioned by a mechanism on the 
network into a set of one or more peer nodes inside the mechanism and a 
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set of one or more peer nodes outside the mechanism, wherein peer nodes 
on opposite sides of the mechanism cannot communicate directly with 
each other on the network; 

wherein the plurality of peer nodes comprises one or more relay peer nodes 
operable to couple to the network outside the mechanism; 

wherein each of the peer nodes inside the mechanism are operable to publish an 
advertisement on the one or more relay peer nodes; and 

wherein each of the peer nodes outside the mechanism are operable to discover 
the advertisements for the peer nodes inside the mechanism published on 
the one or more relay peer nodes. 

12. (Original) The peer computing system as recited in claim 11, wherein the 
mechanism is a firewall. 

13. (Original) The peer computing system as recited in claim 11, wherein the 
mechanism is a Network Address Translation (NAT) gateway. 

14. (Original) The peer computing system as recited in claim 11, wherein the one 
or more relay peer nodes are further operable to relay messages between the peer nodes 
outside the mechanism and the peer nodes inside the mechanism. 

15. (Original) The peer computing system as recited in claim 14, wherein the 
relay peer node is further operable to cache route information describing one or more 
routes to peer nodes on the network. 

16. (Currently amended) The peer computing system as recited in claim 15, 
wherein, to relay the messages between the peer nodes, the relay peer is operable to use 
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the cached route information to route the received messages to the peer nodes outside 
inside the mechanism. 

17. (Original) The peer computing system as recited in claim 15, wherein the 
route information includes an ordered sequence of peer identifiers configured for use in 
routing a message to a destination peer node. 

18. (Currently amended) The peer computing system as recited in claim 14, 
wherein the message includes route information, and wherein, to relay the messages 
between the peer nodes, the relay peer is operable to use the route information included in 
the messages to route the received messages to the peer nodes outside inside the 
mechanism. 

19. (Original) The peer computing system as recited in claim 18, wherein the 
route information includes an ordered sequence of peer identifiers configured for use in 
routing a message to a destination peer node. 

20. (Currently amended) A peer node A comprising: 
a network interface for coupling to a network; 

a memory comprising program instructions, wherein the program instructions are 
executable within the peer node to, according to [[a]] one or more peer-to- 
peer platform protocols : 

discover other peer nodes on the network; 

communicate with other peer nodes on the network; 

cooperate with other peer nodes on the network to form peer groups; 
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host shared content on the network; 



receive a message from a source peer node on the network intended for a 
destination peer node, wherein the source peer node and the 
destination peer node cannot communicate directly with each other 
on the network ; and 

relay the message to [[a]] the destination peer noderand 

wherein the peer nodes are configured to implement a peer to peer environment 
on the network according to the pccr - to - pccr platform, wherein the peer - 
to poor platform comprises one - or more poor to poor platform protocols 
for enabling the plurality of peer nodes to — discover each other, 
communicate with each other, and cooperate with each other to form p ee r 
groups and share content in tho poor - to - poor environment . 

2 1 . (Original) The peer node as recited in claim 20, wherein the program 
instructions are further executable to cache route information describing one or more 
routes to other peer nodes on the network. 

22. (Original) The peer node as recited in claim 21, wherein, to relay the message 
to the destination peer node, the program instructions are further executable to: 

locate route information to the destination peer node in the cached route 
information; and 

route the message to the destination peer node using the located route 
information. 
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23. (Original) The peer node as recited in claim 21, wherein the cached route 
information includes ordered sequences of peer identifiers configured for use in routing 
messages to destination peer nodes. 

24. (Original) The peer computing system as recited in claim 21, wherein the 
relay peer node is further operable to: 

receive a query requesting route information to a peer node from another peer 
node, wherein the query is formatted according to an endpoint routing 
protocol; and 

send the requested route information to the requesting peer node in accordance 
with the endpoint routing protocol. 

25. (Original) The peer node as recited in claim 20, wherein the message includes 
route information, and wherein, to relay the message to the destination peer node, the 
program instructions are further executable to route the received message to the 
destination peer node using the route information included in the message. 

26. (Original) The peer node as recited in claim 25, wherein the route information 
includes an ordered sequence of peer identifiers configured for use in routing messages to 
the destination peer node. 

27. (Currently amended) The peer node as recited in claim 20, wherein the 
source peer node is on the outside of a partitioning mechanism on the network, and 
wherein the destination peer node is on the inside of the partitioning mechanis m, wherein 
the source peer node and the destination peer node cannot communicate directly with 
each other on the network across the partitioning mechanism . 

28. (Original) The peer node as recited in claim 27, wherein the partitioning 
mechanism is a firewall. 
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29. (Original) The peer node as recited in claim 27, wherein the partitioning 
mechanism is a Network Address Translation (NAT) gateway. 

30. (Currently amended) A peer computing system, comprising: 
a plurality of peer nodes operable to couple to a network; 

means for the plurality of peer nodes to discover each other, communicate with 
each other, and cooperate with each other to form peer groups and share 
content in a peer-to-peer environment on the network; 

means for partitioning the plurality of peer nodes on the network into a set of one 
or more peer nodes inside the partition and a set of one or more peer nodes 
outside the partition, wherein peer nodes on opposite sides of the partition 
cannot communicate directly with each other on the network; 

means for the peer nodes inside the partition to advertise themselves outside the 
partition; and 

means for the peer nodes outside the mechanism to discover the advertised peer 
nodes inside the partition; 

wherein the means for the peer nodes inside the partition to advertise themselves 
comprises a relay peer node outside the partition, wherein the relay peer 
node comprises means for publishing advertisements for the peer nodes 
inside the partition, and wherein the relay peer node is one of the plurality 
of peer nodes . 

31. (Original) The peer computing system as recited in claim 30, wherein the 
partition is a firewall. 

10/055,097 (5681-07100/P7111) 9 Meyertons, Hood, Kivlin, Kowert & Goetzel, P.C. 



32. (Original) The peer computing system as recited in claim 30, wherein the 
partition is a Network Address Translation (NAT) gateway. 

33. (Original) The peer computing system as recited in claim 30, further 
comprising means for relaying messages between the peer nodes outside the mechanism 
and the peer nodes inside the mechanism. 

34. (Original) The peer computing system as recited in claim 33, wherein the 
means for relaying messages comprises a relay peer node, wherein the relay peer node 
comprises means for caching route information describing one or more routes to peer 
nodes on the network. 

35. (Currently amended) The peer computing system as recited in claim 34, 
wherein, to relay the messages between the peer nodes, the peer computing system 
further comprises means for using the cached route information to route the roooivod 
messages to the peer nodes outside inside the mechanism. 

36. (Currently amended) The peer computing system as recited in claim 33, 
wherein the message includes route information, and wherein, to relay the messages 
between the peer nodes, the relay peer further comprises means for using the route 
information included in the messages to route the received messages to the peer nodes 
outside inside the mechanism. 

37. (Currently amended) A methodi comprising: 

a plurality of peer nodes implementing a peer-to-peer environment on a network 
according to a peer-to-peer platform, wherein the peer-to-peer platform 
comprises one or more peer-to-peer platform protocols for enabling the 
plurality of peer nodes to discover each other, communicate with each 
other, and cooperate with each other to form peer groups and share content 
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in the peer-to-peer environmen t, and wherein each of the plurality of peer 
nodes is a host of content in the peer-to-peer environment ; 



one of the plurality of peer nodes inside a partitioning mechanism on the network 
publishing an advertisement on a relay peer node outside the partitioning 
mechanism, wherein peer nodes inside the partitioning mechanism cannot 
directly communicate with peer nodes outside the partitioning mechanism i 
and wherein the relay peer node is one of the plurality of peer nodes ; 

one of the plurality of peer nodes outside the partitioning mechanism discovering 
the advertisement to the peer node inside the partitioning mechanism on 
the relay peer node; 

the peer node outside the partitioning mechanism sending a message [[to]] 
intended for the peer node inside the partitioning mechanism to the relay 
peer node; and 

the relay peer node relaying the message to the peer node inside the partitioning 
mechanism. 

38. (Original) The method as recited in claim 37, further comprising the relay 
peer node caching route information describing one or more routes to other peer nodes on 
the network, wherein the route information is configured for use in routing messages 
between peer nodes in the peer-to-peer environment. 

39. (Original) The method as recited in claim 38, wherein the cached route 
information includes ordered sequences of peer identifiers configured for use in routing 
messages to destination peer nodes. 

40. (Original) The method as recited in claim 38, further comprising: 
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the relay peer node receiving a query requesting route information to a peer node 
from another peer node, wherein the query is formatted according to an 
endpoint routing protocol; and 

the relay peer node sending the requested route information to the requesting peer 
node in accordance with the endpoint routing protocol. 

41. (Original) The method as recited in claim 37, wherein the message includes 
route information, and wherein, in said relaying the message, the method further 
comprises routing the message to the peer node inside the partitioning mechanism using 
the route information included in the message. 

42. (Original) The method as recited in claim 41, wherein the route information 
includes an ordered sequence of peer identifiers. 

43. (Original) The method as recited in claim 37, wherein the partitioning 
mechanism is a firewall. 

44. (Original) The method as recited in claim 37, wherein the partitioning 
mechanism is a Network Address Translation (NAT) gateway. 

45. (Currently amended) A methodi comprising: 

a plurality of peer nodes implementing a peer-to-peer environment on a network 
according to a peer-to-peer platform, wherein the peer-to-peer platform 
comprises one or more peer-to-peer platform protocols for enabling the 
plurality of peer nodes to discover each other, communicate with each 
other, and cooperate with each other to form peer groups and share content 
in the peer-to-peer environment , and wherein each of the plurality of peer 
nodes is a host of content in the peer-to-peer environment ; 
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wherein one or more of the plurality of peer nodes are relay peer nodes; and 

one of the relay peer nodes caching route information describing one or more 
routes to other peer nodes on the network, wherein the route information is 
configured for use in routing messages between peer nodes in the peer-to- 
peer environment, and wherein the cached route information includes 
ordered sequences of peer identifiers configured for use in routing 
messages to destination peer nodes. 

46. (Original) The method as recited in claim 45, further comprising: 

the relay peer node receiving a query requesting route information to a peer node 
from another peer node, wherein the query is formatted according to an 
endpoint routing protocol; and 

the relay peer node sending the requested route information to the requesting peer 
node in accordance with the endpoint routing protocol. 

47. (Original) The method as recited in claim 45, further comprising: 

one of the plurality of peer nodes inside a partitioning mechanism on the network 
publishing an advertisement on the relay peer node, wherein the relay peer 
node is outside the partitioning mechanism, and wherein peer nodes inside 
the partitioning mechanism cannot directly communicate with peer nodes 
outside the partitioning mechanism; 

one of the plurality of peer nodes outside the partitioning mechanism discovering 
the advertisement to the peer node inside the partitioning mechanism on 
the relay peer node; and 
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the peer node outside the partitioning mechanism and the peer node inside the 
partitioning mechanism exchanging messages through the relay peer node. 

48. (Original) The method as recited in claim 47, further comprising the relay 
peer node using the cached route information to route the messages to the destination 
peer node. 

49. (Original) The method as recited in claim 47, wherein the partitioning 
mechanism is a firewall. 

50. (Original) The method as recited in claim 47, wherein the partitioning 
mechanism is a Network Address Translation (NAT) gateway. 

51. (Currently amended) An article of manufacture comprising A computer- 
readable storage medium storing software instructions computer- executable to 
implement: 

a plurality of peer nodes implementing a peer-to-peer environment on a network 
according to a peer-to-peer platform, wherein the peer-to-peer platform 
comprises one or more peer-to-peer platform protocols for enabling the 
plurality of peer nodes to discover each other, communicate with each 
other, and cooperate with each other to form peer groups and share content 
in the peer-to-peer environment , and wherein each of the plurality of peer 
nodes is a host of content in the peer-to-peer environment ; 

one of the plurality of peer nodes inside a partitioning mechanism on the network 
publishing an advertisement on a relay peer node outside the partitioning 
mechanism, wherein peer nodes inside the partitioning mechanism cannot 
directly communicate with peer nodes outside the partitioning mechanism i 
and wherein the relay peer node is one of the plurality of peer nodes ; 



10/055,097 (5681-07100/P7111) 14 Meyertons, Hood, Kivlin, Kowert & Goetzel, P.C. 



one of the plurality of peer nodes outside the partitioning mechanism discovering 
the advertisement to the peer node inside the partitioning mechanism on 
the relay peer node; 



the peer node outside the partitioning mechanism sending a message [[to]] 
intended for the peer node inside the partitioning mechanism to the relay 
peer node; and 

the relay peer node relaying the message to the peer node inside the partitioning 
mechanism. 

52. (Currently amended) The article of manufacture storage medium as recited in 
claim 51, wherein the software instructions are further executable to implement the relay 
peer node caching route information describing one or more routes to other peer nodes on 
the network, wherein the route information is configured for use in routing messages 
between peer nodes in the peer-to-peer environment. 

53. (Currently amended) The article of manufacture storage medium as recited in 
claim 52, wherein the software instructions are further executable to implement: 

the relay peer node receiving a query requesting route information to a peer node 
from another peer node, wherein the query is formatted according to an 
endpoint routing protocol; and 

the relay peer node sending the requested route information to the requesting peer 
node in accordance with the endpoint routing protocol. 

54. (Currently amended) The article of manufacture storage medium as recited in 
claim 5 1 , wherein the message includes route information, and wherein, in said relaying 
the message, the software instructions are further executable to implement routing the 
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message to the peer node inside the partitioning mechanism using the route information 
included in the message. 



55. (Currently amended) The article of manufacture storage medium as recited in 
claim 5 1 , wherein the partitioning mechanism is a firewall. 

56. (Currently amended) The article of manufacture storage medium as recited in 
claim 51, wherein the partitioning mechanism is a Network Address Translation (NAT) 
gateway. 

57. (Currently amended) An article of manufacture comprising A computer- 
readable storage medium storing software instructions computer- executable to 
implement: 

a plurality of peer nodes implementing a peer-to-peer environment on a network 
according to a peer-to-peer platform, wherein the peer-to-peer platform 
comprises one or more peer-to-peer platform protocols for enabling the 
plurality of peer nodes to discover each other, communicate with each 
other, and cooperate with each other to form peer groups and share content 
in the peer-to-peer environment , and wherein each of the plurality of peer 
nodes is a host of content in the peer-to-peer environment ; 

one or more of the plurality of peer nodes implementing a relay service in 
accordance with the peer-to-peer platform to perform as relay peer nodes; 
and 

one of the relay peer nodes caching route information describing one or more 
routes to other peer nodes on the network, wherein the route information is 
configured for use in routing messages between peer nodes in the peer-to- 
peer environment, and wherein the cached route information includes 
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ordered sequences of peer identifiers configured for use in routing 
messages to destination peer nodes. 

58. (Currently amended) The article of manufacture storage medium as recited in 
claim 57, wherein the software instructions are further executable to implement: 

the relay peer node receiving a query requesting route information to a peer node 
from another peer node, wherein the query is formatted according to an 
endpoint routing protocol; and 

the relay peer node sending the requested route information to the requesting peer 
node in accordance with the endpoint routing protocol. 

59. (Currently amended) The article of manufacture storage medium as recited in 
claim 57, wherein the software instructions are further executable to implement: 

one of the plurality of peer nodes inside a partitioning mechanism on the network 
publishing an advertisement on the relay peer node, wherein the relay peer 
node is outside the partitioning mechanism, and wherein peer nodes inside 
the partitioning mechanism cannot directly communicate with peer nodes 
outside the partitioning mechanism; 

one of the plurality of peer nodes outside the partitioning mechanism discovering 
the advertisement to the peer node inside the partitioning mechanism on 
the relay peer node; and 

the peer node outside the partitioning mechanism and the peer node inside the 
partitioning mechanism exchanging messages through the relay peer node. 

60. (Currently amended) The article of manufacture storage medium as recited in 
claim 59, wherein the software instructions are further executable to implement the relay 
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peer node using the cached route information to route the messages to the destination 
peer node. 



61 . (Currently amended) The article of manufacture storage medium as recited in 
claim 59, wherein the partitioning mechanism is a firewall. 

62. (Currently amended) The article of manufacture storage medium as recited in 
claim 59, wherein the partitioning mechanism is a Network Address Translation (NAT) 
gateway. 
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